<script setup lang="ts">
import axios from 'axios';
import { ref, computed, onMounted } from 'vue'

// 接口地址：http://hmajax.itheima.net/api/news
// 请求方式：get
interface ResData {
    cmtcount: number
    id: number
    img: string
    source: string
    time: string
    title: string
}

interface ResType {
    message: string
    data: ResData[]
}

const list = ref<ResData[]>([])

onMounted(async () => {
    const res = await axios.get<ResType>("http://hmajax.itheima.net/api/news")
    console.log(res.data.data)
    list.value = res.data.data
})


</script>

<template>
    <div id="app">
        <ul>
            <li class="news" v-for="item in list" :key="item.id">
                <div class="left">
                    <div class="title">{{ item.title }}</div>
                    <div class="info">
                        <span>{{ item.source }}</span>
                        <span>{{ item.time }}</span>
                    </div>
                </div>
                <div class="right">
                    <img :src='item.img' alt="">
                </div>
            </li>
        </ul>
    </div>
</template>

<style>
* {
    margin: 0;
    padding: 0;
    list-style: none;
}

.news {
    display: flex;
    height: 120px;
    width: 600px;
    margin: 0 auto;
    padding: 20px 0;
    cursor: pointer;
}

.news .left {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding-right: 10px;
}

.news .left .title {
    font-size: 20px;
}

.news .left .info {
    color: #999999;
}

.news .left .info span {
    margin-right: 20px;
}

.news .right {
    width: 160px;
    height: 120px;
}

.news .right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
</style>